<template>
  <header class="page-heading">
    <div class="page-heading__leading">
      <div class="page-heading__crumbs">
        <p-bread-crumbs :class="classes" :crumbs="crumbs" />
        <slot name="after-crumbs" />
      </div>
      <slot />
    </div>

    <div class="page-heading__trailing">
      <slot name="actions" />
    </div>
  </header>
</template>

<script lang="ts" setup>
  import { PBreadCrumbs, BreadCrumbs } from '@prefecthq/prefect-design'
  import { computed } from 'vue'
  import { Size } from '@/types'

  const props = withDefaults(defineProps<{
    crumbs: BreadCrumbs,
    size?: Size,
  }>(), {
    size: 'xl',
  })

  const classes = computed(() => ({
    'page-heading__crumbs--xs': props.size === 'xs',
    'page-heading__crumbs--sm': props.size === 'sm',
    'page-heading__crumbs--md': props.size === 'md',
    'page-heading__crumbs--lg': props.size === 'lg',
    'page-heading__crumbs--xl': props.size === 'xl',
  }))
</script>

<style>
.page-heading { @apply
  flex
  gap-2
  items-center
}

.page-heading__leading { @apply
  flex
  flex-col
  gap-2
}

.page-heading__crumbs { @apply
  flex
  items-center
  justify-start
  gap-2
  flex-wrap
}

.page-heading__trailing { @apply
  flex
  flex-grow
  items-center
  justify-end
  gap-2
  min-w-0
  max-w-full
}

.page-heading__crumbs--xs { @apply
  text-xs
}

.page-heading__crumbs--sm { @apply
  text-sm
}

.page-heading__crumbs--md { @apply
  text-base
}

.page-heading__crumbs--lg { @apply
  text-lg
}

.page-heading__crumbs--xl { @apply
  text-xl
}
</style>